[INFO] cloning repository https://github.com/GlebMan-n/synoplayer
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/GlebMan-n/synoplayer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGlebMan-n%2Fsynoplayer", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGlebMan-n%2Fsynoplayer'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 7f82b64a68f3b020610c5e4a432f46c4e8a75ce4
[INFO] testing GlebMan-n/synoplayer against master#f9988fefd3add01f414f52b414308e7872622fee for pr-155114
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FGlebMan-n%2Fsynoplayer" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/GlebMan-n/synoplayer
[INFO] finished tweaking git repo https://github.com/GlebMan-n/synoplayer
[INFO] tweaked toml for git repo https://github.com/GlebMan-n/synoplayer written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/GlebMan-n/synoplayer on toolchain f9988fefd3add01f414f52b414308e7872622fee
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/GlebMan-n/synoplayer already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded wiremock v0.6.5
[INFO] [stderr]   Downloaded tokio-test v0.4.5
[INFO] [stderr]   Downloaded cookie_store v0.22.1
[INFO] [stderr]   Downloaded instability v0.3.12
[INFO] [stderr]   Downloaded predicates-core v1.0.10
[INFO] [stderr]   Downloaded float-cmp v0.10.0
[INFO] [stderr]   Downloaded clap_complete v4.6.0
[INFO] [stderr]   Downloaded predicates v3.1.4
[INFO] [stderr]   Downloaded assert_cmd v2.2.0
[INFO] [stderr]   Downloaded predicates-tree v1.0.13
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 1668973c7c6d5cd070493eb14cd88b5f8ce9b69e9f5b08f1ef4cf695faec6dfb
[INFO] running `Command { std: "docker" "start" "-a" "1668973c7c6d5cd070493eb14cd88b5f8ce9b69e9f5b08f1ef4cf695faec6dfb", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "1668973c7c6d5cd070493eb14cd88b5f8ce9b69e9f5b08f1ef4cf695faec6dfb", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1668973c7c6d5cd070493eb14cd88b5f8ce9b69e9f5b08f1ef4cf695faec6dfb", kill_on_drop: false }`
[INFO] [stdout] 1668973c7c6d5cd070493eb14cd88b5f8ce9b69e9f5b08f1ef4cf695faec6dfb
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 231651e98144d850baca6ee372dc0297043e59231d32c5272da2227730c73b5d
[INFO] running `Command { std: "docker" "start" "-a" "231651e98144d850baca6ee372dc0297043e59231d32c5272da2227730c73b5d", kill_on_drop: false }`
[INFO] [stderr]    Compiling bytes v1.11.1
[INFO] [stderr]    Compiling getrandom v0.2.17
[INFO] [stderr]    Compiling futures-task v0.3.32
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling tracing v0.1.44
[INFO] [stderr]    Compiling zerofrom v0.1.6
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling num-conv v0.2.0
[INFO] [stderr]    Compiling time-core v0.1.8
[INFO] [stderr]    Compiling deranged v0.5.8
[INFO] [stderr]    Compiling cookie v0.18.1
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]    Compiling regex-syntax v0.8.10
[INFO] [stderr]    Compiling psl-types v2.0.11
[INFO] [stderr]    Compiling instability v0.3.12
[INFO] [stderr]    Compiling ring v0.17.14
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling yoke v0.8.1
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling rand_core v0.6.4
[INFO] [stderr]    Compiling clap_builder v4.6.0
[INFO] [stderr]    Compiling signal-hook-mio v0.2.5
[INFO] [stderr]    Compiling ppv-lite86 v0.2.21
[INFO] [stderr]    Compiling time-macros v0.2.27
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling clap_derive v4.6.0
[INFO] [stderr]    Compiling openssl v0.10.76
[INFO] [stderr]    Compiling toml_write v0.1.2
[INFO] [stderr]    Compiling zerovec v0.11.5
[INFO] [stderr]    Compiling zerotrie v0.2.3
[INFO] [stderr]    Compiling toml_datetime v0.6.11
[INFO] [stderr]    Compiling serde_spanned v0.6.9
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]    Compiling winnow v0.7.15
[INFO] [stderr]    Compiling option-ext v0.2.0
[INFO] [stderr]    Compiling dirs-sys v0.5.0
[INFO] [stderr]    Compiling rand_chacha v0.3.1
[INFO] [stderr]    Compiling tokio v1.50.0
[INFO] [stderr]    Compiling tinystr v0.8.2
[INFO] [stderr]    Compiling potential_utf v0.1.4
[INFO] [stderr]    Compiling http v1.4.0
[INFO] [stderr]    Compiling icu_collections v2.1.1
[INFO] [stderr]    Compiling icu_locale_core v2.1.1
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling crossterm v0.28.1
[INFO] [stderr]    Compiling time v0.3.47
[INFO] [stderr]    Compiling icu_provider v2.1.1
[INFO] [stderr]    Compiling http-body v1.0.1
[INFO] [stderr]    Compiling icu_properties v2.1.2
[INFO] [stderr]    Compiling icu_normalizer v2.1.1
[INFO] [stderr]    Compiling rustls-webpki v0.103.9
[INFO] [stderr]    Compiling http-body-util v0.1.3
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling toml_edit v0.22.27
[INFO] [stderr]    Compiling thiserror-impl v2.0.18
[INFO] [stderr]    Compiling chrono v0.4.44
[INFO] [stderr]    Compiling ratatui v0.29.0
[INFO] [stderr]    Compiling dirs v6.0.0
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling rustls v0.23.37
[INFO] [stderr]    Compiling clap v4.6.0
[INFO] [stderr]    Compiling clap_complete v4.6.0
[INFO] [stderr]    Compiling idna_adapter v1.2.1
[INFO] [stderr]    Compiling idna v1.1.0
[INFO] [stderr]    Compiling native-tls v0.2.18
[INFO] [stderr]    Compiling url v2.5.8
[INFO] [stderr]    Compiling publicsuffix v2.3.0
[INFO] [stderr]    Compiling thiserror v2.0.18
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling tracing-subscriber v0.3.23
[INFO] [stderr]    Compiling cookie_store v0.22.1
[INFO] [stderr]    Compiling toml v0.8.23
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling synoplayer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 52.61s
[INFO] running `Command { std: "docker" "inspect" "231651e98144d850baca6ee372dc0297043e59231d32c5272da2227730c73b5d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "231651e98144d850baca6ee372dc0297043e59231d32c5272da2227730c73b5d", kill_on_drop: false }`
[INFO] [stdout] 231651e98144d850baca6ee372dc0297043e59231d32c5272da2227730c73b5d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 5363a6cc265d9db96dbc32c52b486be6a85aab35bd44f203ac75dfd588547149
[INFO] running `Command { std: "docker" "start" "-a" "5363a6cc265d9db96dbc32c52b486be6a85aab35bd44f203ac75dfd588547149", kill_on_drop: false }`
[INFO] [stderr]    Compiling tokio v1.50.0
[INFO] [stderr]    Compiling futures-macro v0.3.32
[INFO] [stderr]    Compiling regex-automata v0.4.14
[INFO] [stderr]    Compiling serde_json v1.0.149
[INFO] [stderr]    Compiling rustix v1.1.4
[INFO] [stderr]    Compiling predicates-core v1.0.10
[INFO] [stderr]    Compiling float-cmp v0.10.0
[INFO] [stderr]    Compiling num_cpus v1.17.0
[INFO] [stderr]    Compiling difflib v0.4.0
[INFO] [stderr]    Compiling termtree v0.5.1
[INFO] [stderr]    Compiling normalize-line-endings v0.3.0
[INFO] [stderr]    Compiling deadpool-runtime v0.1.4
[INFO] [stderr]    Compiling assert_cmd v2.2.0
[INFO] [stderr]    Compiling wait-timeout v0.2.1
[INFO] [stderr]    Compiling predicates-tree v1.0.13
[INFO] [stderr]    Compiling futures-util v0.3.32
[INFO] [stderr]    Compiling cookie_store v0.22.1
[INFO] [stderr]    Compiling assert-json-diff v2.0.2
[INFO] [stderr]    Compiling tempfile v3.27.0
[INFO] [stderr]    Compiling matchers v0.2.0
[INFO] [stderr]    Compiling regex v1.12.3
[INFO] [stderr]    Compiling bstr v1.12.1
[INFO] [stderr]    Compiling tracing-subscriber v0.3.23
[INFO] [stderr]    Compiling predicates v3.1.4
[INFO] [stderr]    Compiling futures-executor v0.3.32
[INFO] [stderr]    Compiling futures v0.3.32
[INFO] [stderr]    Compiling tokio-util v0.7.18
[INFO] [stderr]    Compiling tokio-native-tls v0.3.1
[INFO] [stderr]    Compiling tower v0.5.3
[INFO] [stderr]    Compiling tokio-rustls v0.26.4
[INFO] [stderr]    Compiling tokio-stream v0.1.18
[INFO] [stderr]    Compiling deadpool v0.12.3
[INFO] [stderr]    Compiling tower-http v0.6.8
[INFO] [stderr]    Compiling tokio-test v0.4.5
[INFO] [stderr]    Compiling h2 v0.4.13
[INFO] [stderr]    Compiling hyper v1.8.1
[INFO] [stderr]    Compiling hyper-util v0.1.20
[INFO] [stderr]    Compiling hyper-tls v0.6.0
[INFO] [stderr]    Compiling hyper-rustls v0.27.7
[INFO] [stderr]    Compiling wiremock v0.6.5
[INFO] [stderr]    Compiling reqwest v0.12.28
[INFO] [stderr]    Compiling synoplayer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: function `test_track` is never used
[INFO] [stdout]    --> src/player/engine.rs:437:8
[INFO] [stdout]     |
[INFO] [stdout] 437 |     fn test_track() -> TrackInfo {
[INFO] [stdout]     |        ^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 45.69s
[INFO] running `Command { std: "docker" "inspect" "5363a6cc265d9db96dbc32c52b486be6a85aab35bd44f203ac75dfd588547149", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "5363a6cc265d9db96dbc32c52b486be6a85aab35bd44f203ac75dfd588547149", kill_on_drop: false }`
[INFO] [stdout] 5363a6cc265d9db96dbc32c52b486be6a85aab35bd44f203ac75dfd588547149
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+f9988fefd3add01f414f52b414308e7872622fee" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 27082b1bcd840fe671d2bb0cfd907f24f745d0452783fb81a487deb4752bd2fb
[INFO] running `Command { std: "docker" "start" "-a" "27082b1bcd840fe671d2bb0cfd907f24f745d0452783fb81a487deb4752bd2fb", kill_on_drop: false }`
[INFO] [stderr] warning: function `test_track` is never used
[INFO] [stderr]    --> src/player/engine.rs:437:8
[INFO] [stderr]     |
[INFO] [stderr] 437 |     fn test_track() -> TrackInfo {
[INFO] [stderr]     |        ^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `synoplayer` (lib test) generated 1 warning
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.49s
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/synoplayer-bdc4ffe7025d6cf3)
[INFO] [stdout] 
[INFO] [stdout] running 149 tests
[INFO] [stdout] test api::album::tests::list_albums_parses_response ... ok
[INFO] [stdout] test api::client::tests::new_client_is_not_authenticated ... ok
[INFO] [stdout] test api::client::tests::set_and_clear_sid ... ok
[INFO] [stdout] test api::auth::tests::login_returns_2fa_required ... ok
[INFO] [stdout] test api::client::tests::build_url_with_discovered_path ... ok
[INFO] [stdout] test api::client::tests::request_success_parses_data ... ok
[INFO] [stdout] test api::artist::tests::list_artists_parses_response ... ok
[INFO] [stdout] test api::auth::tests::discover_populates_api_paths ... ok
[INFO] [stdout] test api::client::tests::build_url_fallback_for_known_apis ... ok
[INFO] [stdout] test api::auth::tests::login_sets_sid_on_success ... ok
[INFO] [stdout] test api::auth::tests::login_returns_error_on_wrong_password ... ok
[INFO] [stdout] test api::client::tests::base_url_strips_trailing_slash ... ok
[INFO] [stdout] test api::composer::tests::list_composers_parses_response ... ok
[INFO] [stdout] test api::client::tests::request_session_expired_returns_session_error ... ok
[INFO] [stdout] test api::client::tests::build_url_unknown_api_fails ... ok
[INFO] [stdout] test api::client::tests::request_error_returns_syno_error ... ok
[INFO] [stdout] test api::cover::tests::cover_url_contains_song_id ... ok
[INFO] [stdout] test api::auth::tests::logout_clears_sid ... ok
[INFO] [stdout] test api::folder::tests::list_subfolder ... ok
[INFO] [stdout] test api::favorites::tests::list_returns_songs_from_playlist ... ok
[INFO] [stdout] test api::folder::tests::list_root_folders ... ok
[INFO] [stdout] test api::pin::tests::list_returns_total_count ... ok
[INFO] [stdout] test api::playlist::tests::create_playlist_sends_name ... ok
[INFO] [stdout] test api::favorites::tests::list_returns_empty_when_no_playlist ... ok
[INFO] [stdout] test api::pin::tests::list_pinned_items ... ok
[INFO] [stdout] test api::playlist::tests::delete_playlist_sends_id ... ok
[INFO] [stdout] test api::pin::tests::unpin_sends_id ... ok
[INFO] [stdout] test api::pin::tests::list_parses_item_types ... ok
[INFO] [stdout] test api::playlist::tests::list_playlists_parses_response ... ok
[INFO] [stdout] test api::genre::tests::list_genres_parses_response ... ok
[INFO] [stdout] test api::playlist::tests::update_songs_deletes_and_recreates ... ok
[INFO] [stdout] test api::playlist::tests::get_playlist_info_returns_songs ... ok
[INFO] [stdout] test api::lyrics::tests::get_lyrics_parses_text ... ok
[INFO] [stdout] test api::pin::tests::pin_sends_id ... ok
[INFO] [stdout] test cache::manager::tests::cleanup_expired_removes_old_entries ... ok
[INFO] [stdout] test cache::manager::tests::clear_older_than_days_removes_old_entries ... ok
[INFO] [stdout] test cache::manager::tests::clear_removes_all ... ok
[INFO] [stdout] test cache::manager::tests::disabled_cache_does_not_store ... ok
[INFO] [stdout] test cache::manager::tests::file_path_returns_local_path ... ok
[INFO] [stdout] test cache::manager::tests::get_entry_meta_returns_none_for_missing ... ok
[INFO] [stdout] test cache::manager::tests::integrity_check_detects_corruption ... ok
[INFO] [stdout] test cache::manager::tests::get_entry_meta_returns_stored_metadata ... ok
[INFO] [stdout] test cache::manager::tests::list_entries_returns_all_cached ... ok
[INFO] [stdout] test cache::manager::tests::miss_returns_none ... ok
[INFO] [stdout] test cache::manager::tests::put_with_meta_stores_song_metadata ... ok
[INFO] [stdout] test cache::manager::tests::put_without_meta_has_empty_metadata_fields ... ok
[INFO] [stdout] test cache::manager::tests::status_reports_correct_stats ... ok
[INFO] [stdout] test cache::manager::tests::store_and_retrieve ... ok
[INFO] [stdout] test cache::storage::tests::content_hash_detects_changes ... ok
[INFO] [stdout] test cache::storage::tests::delete_removes_file ... ok
[INFO] [stdout] test api::radio::tests::add_radio_station_sends_params ... ok
[INFO] [stdout] test cache::storage::tests::file_count_counts_audio_files ... ok
[INFO] [stdout] test cache::storage::tests::hash_id_differs_for_different_ids ... ok
[INFO] [stdout] test cache::storage::tests::hash_id_is_deterministic ... ok
[INFO] [stdout] test cache::storage::tests::read_nonexistent_returns_error ... ok
[INFO] [stdout] test cache::storage::tests::total_size_sums_files ... ok
[INFO] [stdout] test cache::storage::tests::write_and_read_roundtrip ... ok
[INFO] [stdout] test config::model::tests::base_url_http ... ok
[INFO] [stdout] test api::radio::tests::list_radio_stations ... ok
[INFO] [stdout] test config::model::tests::base_url_https ... ok
[INFO] [stdout] test config::model::tests::defaults_when_optional_missing ... ok
[INFO] [stdout] test config::model::tests::empty_string_parses_to_defaults ... ok
[INFO] [stdout] test config::model::tests::serialize_roundtrip ... ok
[INFO] [stdout] test config::model::tests::parse_full_config ... ok
[INFO] [stdout] test credentials::store::tests::base64_roundtrip ... ok
[INFO] [stdout] test credentials::store::tests::encrypted_file_clear ... ok
[INFO] [stdout] test credentials::store::tests::encrypted_file_overwrite ... ok
[INFO] [stdout] test credentials::store::tests::encrypted_file_save_and_load ... ok
[INFO] [stdout] test credentials::store::tests::exists_returns_false_when_empty ... ok
[INFO] [stdout] test credentials::store::tests::load_from_nonexistent_returns_none ... ok
[INFO] [stdout] test api::playlist::tests::rename_playlist_sends_params ... ok
[INFO] [stdout] test cache::storage::tests::exists_returns_true_after_write ... ok
[INFO] [stdout] test history::tests::clear_removes_all ... ok
[INFO] [stdout] test history::tests::empty_history_returns_empty ... ok
[INFO] [stdout] test credentials::store::tests::base64_unicode_roundtrip ... ok
[INFO] [stdout] test history::tests::add_and_list ... ok
[INFO] [stdout] test ipc::client::tests::send_to_nonexistent_socket_fails ... ok
[INFO] [stdout] test ipc::protocol::tests::error_response ... ok
[INFO] [stdout] test ipc::protocol::tests::malformed_json_fails ... ok
[INFO] [stdout] test ipc::protocol::tests::request_serialize_roundtrip ... ok
[INFO] [stdout] test ipc::protocol::tests::response_ok_without_data ... ok
[INFO] [stdout] test history::tests::entries_persist_across_instances ... ok
[INFO] [stdout] test ipc::protocol::tests::response_with_now_playing ... ok
[INFO] [stdout] test history::tests::max_entries_trims_oldest ... ok
[INFO] [stdout] test ipc::server::tests::server_handles_malformed_json ... ok
[INFO] [stdout] test ipc::tests::check_existing_socket_nonexistent ... ok
[INFO] [stdout] test ipc::tests::check_existing_socket_stale ... ok
[INFO] [stdout] test ipc::tests::socket_guard_removes_file ... ok
[INFO] [stdout] test ipc::tests::socket_path_is_absolute ... ok
[INFO] [stdout] test playback::tests::format_duration_minutes_seconds ... ok
[INFO] [stdout] test playback::tests::format_duration_zero ... ok
[INFO] [stdout] test history::tests::list_respects_limit ... ok
[INFO] [stdout] test ipc::protocol::tests::response_with_queue_list ... ok
[INFO] [stdout] test ipc::server::tests::server_start_and_connect ... ok
[INFO] [stdout] test playback::tests::song_meta_extracts_tag_fields ... ok
[INFO] [stdout] test playback::tests::track_from_song_with_metadata ... ok
[INFO] [stdout] test playback::tests::track_from_song_without_additional ... ok
[INFO] [stdout] test player::engine::tests::default_volume_is_80 ... ok
[INFO] [stdout] test player::engine::tests::new_engine_is_stopped ... ok
[INFO] [stdout] test player::engine::tests::stop_from_stopped_is_noop ... ok
[INFO] [stdout] test api::song::tests::set_rating_sends_correct_params ... ok
[INFO] [stdout] test player::queue::tests::clear_empties_queue ... ok
[INFO] [stdout] test player::queue::tests::add_and_current ... ok
[INFO] [stdout] test player::engine::tests::which_exists_finds_sh ... ok
[INFO] [stdout] test player::engine::tests::which_exists_fails_for_nonexistent ... ok
[INFO] [stdout] test player::queue::tests::from_songs_sets_current_to_first ... ok
[INFO] [stdout] test player::queue::tests::new_queue_is_empty ... ok
[INFO] [stdout] test player::queue::tests::next_advances ... ok
[INFO] [stdout] test player::engine::tests::set_volume_clamps_to_100 ... ok
[INFO] [stdout] test player::queue::tests::next_at_end_returns_false ... ok
[INFO] [stdout] test player::queue::tests::prev_at_start_returns_false ... ok
[INFO] [stdout] test player::queue::tests::prev_goes_back ... ok
[INFO] [stdout] test player::queue::tests::prev_on_empty_returns_false ... ok
[INFO] [stdout] test player::queue::tests::remove_adjusts_index ... ok
[INFO] [stdout] test player::queue::tests::remove_current_adjusts ... ok
[INFO] [stdout] test player::queue::tests::remove_last_when_current_adjusts ... ok
[INFO] [stdout] test player::queue::tests::repeat_all_prev_wraps_around ... ok
[INFO] [stdout] test api::stream::tests::stream_url_fails_without_auth ... ok
[INFO] [stdout] test player::queue::tests::repeat_all_wraps_around ... ok
[INFO] [stdout] test player::queue::tests::repeat_one_stays_on_track ... ok
[INFO] [stdout] test player::queue::tests::from_empty_songs_has_no_current ... ok
[INFO] [stdout] test player::queue::tests::shuffle_keeps_current_at_front ... ok
[INFO] [stdout] test player::queue::tests::shuffle_preserves_all_songs ... ok
[INFO] [stdout] test player::state::tests::initial_state_is_stopped ... ok
[INFO] [stdout] test player::state::tests::pause_from_playing ... ok
[INFO] [stdout] test player::state::tests::pause_from_stopped_does_nothing ... ok
[INFO] [stdout] test player::state::tests::play_creates_playing_state ... ok
[INFO] [stdout] test player::state::tests::resume_from_paused ... ok
[INFO] [stdout] test player::state::tests::resume_from_stopped_does_nothing ... ok
[INFO] [stdout] test player::state::tests::stop_from_paused ... ok
[INFO] [stdout] test player::state::tests::stop_from_playing ... ok
[INFO] [stdout] test player::state::tests::track_info_accessible_in_playing_and_paused ... ok
[INFO] [stdout] test tui::app::tests::now_playing_progress ... ok
[INFO] [stdout] test tui::app::tests::now_playing_zero_duration ... ok
[INFO] [stdout] test tui::app::tests::stateful_list_empty ... ok
[INFO] [stdout] test tui::app::tests::stateful_list_next_previous ... ok
[INFO] [stdout] test tui::app::tests::stateful_list_page_navigation ... ok
[INFO] [stdout] test tui::app::tests::tab_switching ... ok
[INFO] [stdout] test player::queue::tests::next_on_empty_returns_false ... ok
[INFO] [stdout] test cache::manager::tests::lru_eviction_removes_oldest ... ok
[INFO] [stdout] test api::song::tests::get_info_returns_song_with_rating ... ok
[INFO] [stdout] test api::song::tests::list_includes_rating_in_additional ... ok
[INFO] [stdout] test api::song::tests::list_songs_parses_response ... ok
[INFO] [stdout] test api::search::tests::search_returns_songs_albums_artists ... ok
[INFO] [stdout] test api::song::tests::clear_rating_sends_zero ... ok
[INFO] [stdout] test api::song::tests::search_songs_sends_keyword ... ok
[INFO] [stdout] test api::stream::tests::stream_url_contains_song_id_and_sid ... ok
[INFO] [stdout] test api::stream::tests::transcode_url_uses_transcode_method ... ok
[INFO] [stdout] test api::stream::tests::stream_bytes_returns_audio_data ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 149 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.32s
[INFO] [stdout] 
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/synoplayer-aca5558d20210df7)
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/api_parsing.rs (/opt/rustwide/target/debug/deps/api_parsing-796261c21191480d)
[INFO] [stdout] 
[INFO] [stdout] running 13 tests
[INFO] [stdout] test parse_album_list_response ... ok
[INFO] [stdout] test parse_auth_login_2fa ... ok
[INFO] [stdout] test parse_auth_login_success ... ok
[INFO] [stdout] test parse_auth_login_wrong_password ... ok
[INFO] [stdout] test parse_error_session_expired ... ok
[INFO] [stdout] test parse_playlist_list_response ... ok
[INFO] [stdout] test pin_item_display_name_prefers_name_over_title ... ok
[INFO] [stdout] test parse_song_list_response ... ok
[INFO] [stdout] test parse_song_rating_range ... ok
[INFO] [stdout] test parse_api_info_response ... ok
[INFO] [stdout] test parse_pin_list_response ... ok
[INFO] [stdout] test error_code_mapping ... ok
[INFO] [stdout] test parse_error_no_permission ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 13 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.05s
[INFO] [stdout] 
[INFO] [stderr]      Running tests/cli_integration.rs (/opt/rustwide/target/debug/deps/cli_integration-668418e19c876d4b)
[INFO] [stdout] 
[INFO] [stdout] running 18 tests
[INFO] [stdout] test cli_download_help ... ok
[INFO] [stdout] test cli_playlist_play_help_shows_repeat ... ok
[INFO] [stdout] test cli_help_shows_usage ... ok
[INFO] [stdout] test cli_history_help ... ok
[INFO] [stdout] test cli_unknown_command_fails ... ok
[INFO] [stdout] test cli_config_show_works ... ok
[INFO] [stdout] test cli_no_tui_is_valid_subcommand ... ok
[INFO] [stdout] test cli_history_no_args_works ... ok
[INFO] [stdout] test cli_cache_status_works ... ok
[INFO] [stdout] test cli_rate_requires_args ... ok
[INFO] [stdout] test cli_rate_help ... ok
[INFO] [stdout] test cli_version_shows_version ... ok
[INFO] [stdout] test cli_favorites_help ... ok
[INFO] [stdout] test cli_tui_help ... ok
[INFO] [stdout] test cli_help_lists_tui_command ... ok
[INFO] [stdout] test cli_download_without_args_tries_current_track ... ok
[INFO] [stdout] test cli_unfavorite_without_args_tries_current_track ... ok
[INFO] [stdout] test cli_favorite_without_args_tries_current_track ... ok
[INFO] [stderr]    Doc-tests synoplayer
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 18 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.12s
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "27082b1bcd840fe671d2bb0cfd907f24f745d0452783fb81a487deb4752bd2fb", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "27082b1bcd840fe671d2bb0cfd907f24f745d0452783fb81a487deb4752bd2fb", kill_on_drop: false }`
[INFO] [stdout] 27082b1bcd840fe671d2bb0cfd907f24f745d0452783fb81a487deb4752bd2fb
